mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 01:00:13 +00:00 
			
		
		
		
	kdocs for triggers in behaviour builder
This commit is contained in:
		| @@ -10,6 +10,13 @@ import kotlinx.serialization.encoding.Encoder | |||||||
| import kotlinx.serialization.json.JsonNull | import kotlinx.serialization.json.JsonNull | ||||||
| import kotlinx.serialization.json.JsonObject | import kotlinx.serialization.json.JsonObject | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Common interface for any known telegram location. Use [LocationSerializer] in case you wish | ||||||
|  |  * to serialize/deserialize [Location] | ||||||
|  |  * | ||||||
|  |  * @see dev.inmo.tgbotapi.extensions.utils.asStaticLocation | ||||||
|  |  * @see dev.inmo.tgbotapi.extensions.utils.asLiveLocation | ||||||
|  |  */ | ||||||
| @Serializable(LocationSerializer::class) | @Serializable(LocationSerializer::class) | ||||||
| sealed interface Location : Locationed, HorizontallyAccured | sealed interface Location : Locationed, HorizontallyAccured | ||||||
|  |  | ||||||
|   | |||||||
| @@ -121,7 +121,15 @@ suspend fun BehaviourContext.onUnknownCallbackQueryType( | |||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onDataCallbackQuery( | suspend fun BehaviourContext.onDataCallbackQuery( | ||||||
|     initialFilter: SimpleFilter<DataCallbackQuery>? = null, |     initialFilter: SimpleFilter<DataCallbackQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, DataCallbackQuery, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, DataCallbackQuery, Update>? = CallbackQueryFilterByUser, | ||||||
| @@ -133,6 +141,16 @@ suspend fun BehaviourContext.onDataCallbackQuery( | |||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onGameShortNameCallbackQuery( | suspend fun BehaviourContext.onGameShortNameCallbackQuery( | ||||||
|     initialFilter: SimpleFilter<GameShortNameCallbackQuery>? = null, |     initialFilter: SimpleFilter<GameShortNameCallbackQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, GameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, GameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser, | ||||||
| @@ -144,6 +162,16 @@ suspend fun BehaviourContext.onGameShortNameCallbackQuery( | |||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onInlineMessageIdCallbackQuery( | suspend fun BehaviourContext.onInlineMessageIdCallbackQuery( | ||||||
|     initialFilter: SimpleFilter<InlineMessageIdCallbackQuery>? = null, |     initialFilter: SimpleFilter<InlineMessageIdCallbackQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, InlineMessageIdCallbackQuery, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, InlineMessageIdCallbackQuery, Update>? = CallbackQueryFilterByUser, | ||||||
| @@ -155,6 +183,16 @@ suspend fun BehaviourContext.onInlineMessageIdCallbackQuery( | |||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onInlineMessageIdDataCallbackQuery( | suspend fun BehaviourContext.onInlineMessageIdDataCallbackQuery( | ||||||
|     initialFilter: SimpleFilter<InlineMessageIdDataCallbackQuery>? = null, |     initialFilter: SimpleFilter<InlineMessageIdDataCallbackQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, InlineMessageIdDataCallbackQuery, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, InlineMessageIdDataCallbackQuery, Update>? = CallbackQueryFilterByUser, | ||||||
| @@ -166,6 +204,16 @@ suspend fun BehaviourContext.onInlineMessageIdDataCallbackQuery( | |||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onInlineMessageIdGameShortNameCallbackQuery( | suspend fun BehaviourContext.onInlineMessageIdGameShortNameCallbackQuery( | ||||||
|     initialFilter: SimpleFilter<InlineMessageIdGameShortNameCallbackQuery>? = null, |     initialFilter: SimpleFilter<InlineMessageIdGameShortNameCallbackQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, InlineMessageIdGameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, InlineMessageIdGameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser, | ||||||
| @@ -177,6 +225,16 @@ suspend fun BehaviourContext.onInlineMessageIdGameShortNameCallbackQuery( | |||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onMessageCallbackQuery( | suspend fun BehaviourContext.onMessageCallbackQuery( | ||||||
|     initialFilter: SimpleFilter<MessageCallbackQuery>? = null, |     initialFilter: SimpleFilter<MessageCallbackQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, MessageCallbackQuery, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, MessageCallbackQuery, Update>? = CallbackQueryFilterByUser, | ||||||
| @@ -188,6 +246,16 @@ suspend fun BehaviourContext.onMessageCallbackQuery( | |||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onMessageDataCallbackQuery( | suspend fun BehaviourContext.onMessageDataCallbackQuery( | ||||||
|     initialFilter: SimpleFilter<MessageDataCallbackQuery>? = null, |     initialFilter: SimpleFilter<MessageDataCallbackQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, MessageDataCallbackQuery, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, MessageDataCallbackQuery, Update>? = CallbackQueryFilterByUser, | ||||||
| @@ -199,6 +267,16 @@ suspend fun BehaviourContext.onMessageDataCallbackQuery( | |||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onMessageGameShortNameCallbackQuery( | suspend fun BehaviourContext.onMessageGameShortNameCallbackQuery( | ||||||
|     initialFilter: SimpleFilter<MessageGameShortNameCallbackQuery>? = null, |     initialFilter: SimpleFilter<MessageGameShortNameCallbackQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, MessageGameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, MessageGameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser, | ||||||
| @@ -210,6 +288,16 @@ suspend fun BehaviourContext.onMessageGameShortNameCallbackQuery( | |||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onUnknownCallbackQueryType( | suspend fun BehaviourContext.onUnknownCallbackQueryType( | ||||||
|     initialFilter: SimpleFilter<UnknownCallbackQueryType>? = null, |     initialFilter: SimpleFilter<UnknownCallbackQueryType>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, UnknownCallbackQueryType, Update>? = CallbackQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, UnknownCallbackQueryType, Update>? = CallbackQueryFilterByUser, | ||||||
|   | |||||||
| @@ -59,6 +59,15 @@ suspend fun BehaviourContext.onMyChatMemberUpdated( | |||||||
| ) | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onChatMemberUpdated( | suspend fun BehaviourContext.onChatMemberUpdated( | ||||||
|     initialFilter: SimpleFilter<ChatMemberUpdated>? = null, |     initialFilter: SimpleFilter<ChatMemberUpdated>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatMemberUpdated, Update>? = ChatMemberUpdatedFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatMemberUpdated, Update>? = ChatMemberUpdatedFilterByChat, | ||||||
| @@ -71,6 +80,15 @@ suspend fun BehaviourContext.onChatMemberUpdated( | |||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onCommonChatMemberUpdated( | suspend fun BehaviourContext.onCommonChatMemberUpdated( | ||||||
|     initialFilter: SimpleFilter<ChatMemberUpdated>? = null, |     initialFilter: SimpleFilter<ChatMemberUpdated>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatMemberUpdated, Update>? = ChatMemberUpdatedFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatMemberUpdated, Update>? = ChatMemberUpdatedFilterByChat, | ||||||
| @@ -83,6 +101,15 @@ suspend fun BehaviourContext.onCommonChatMemberUpdated( | |||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onMyChatMemberUpdated( | suspend fun BehaviourContext.onMyChatMemberUpdated( | ||||||
|     initialFilter: SimpleFilter<ChatMemberUpdated>? = null, |     initialFilter: SimpleFilter<ChatMemberUpdated>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatMemberUpdated, Update>? = ChatMemberUpdatedFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatMemberUpdated, Update>? = ChatMemberUpdatedFilterByChat, | ||||||
|   | |||||||
| @@ -125,7 +125,7 @@ suspend fun BehaviourContext.command( | |||||||
|     commandRegex: Regex, |     commandRegex: Regex, | ||||||
|     requireOnlyCommandInMessage: Boolean = true, |     requireOnlyCommandInMessage: Boolean = true, | ||||||
|     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||||
| ): Job = onText( | ): Job = onText( | ||||||
| @@ -143,7 +143,7 @@ suspend fun BehaviourContext.command( | |||||||
|     }.let { |     }.let { | ||||||
|         initialFilter ?.times(it) ?: it |         initialFilter ?.times(it) ?: it | ||||||
|     }, |     }, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
| @@ -152,40 +152,40 @@ suspend fun BehaviourContext.command( | |||||||
|     command: String, |     command: String, | ||||||
|     requireOnlyCommandInMessage: Boolean = true, |     requireOnlyCommandInMessage: Boolean = true, | ||||||
|     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||||
| ) = command(command.toRegex(), requireOnlyCommandInMessage, initialFilter, updatesFilter, markerFactory, scenarioReceiver) | ) = command(command.toRegex(), requireOnlyCommandInMessage, initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
| suspend inline fun BehaviourContext.onCommand( | suspend inline fun BehaviourContext.onCommand( | ||||||
|     commandRegex: Regex, |     commandRegex: Regex, | ||||||
|     requireOnlyCommandInMessage: Boolean = true, |     requireOnlyCommandInMessage: Boolean = true, | ||||||
|     noinline initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     noinline initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     noinline updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     noinline subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> |     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||||
| ): Job = command(commandRegex, requireOnlyCommandInMessage, initialFilter, updatesFilter, markerFactory, scenarioReceiver) | ): Job = command(commandRegex, requireOnlyCommandInMessage, initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
| suspend inline fun BehaviourContext.onCommand( | suspend inline fun BehaviourContext.onCommand( | ||||||
|     command: String, |     command: String, | ||||||
|     requireOnlyCommandInMessage: Boolean = true, |     requireOnlyCommandInMessage: Boolean = true, | ||||||
|     noinline initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     noinline initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     noinline updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     noinline subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> |     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||||
| ): Job = onCommand(command.toRegex(), requireOnlyCommandInMessage, initialFilter, updatesFilter, markerFactory, scenarioReceiver) | ): Job = onCommand(command.toRegex(), requireOnlyCommandInMessage, initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
| suspend fun BehaviourContext.commandWithArgs( | suspend fun BehaviourContext.commandWithArgs( | ||||||
|     commandRegex: Regex, |     commandRegex: Regex, | ||||||
|     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTwoTypesReceiver<Unit, CommonMessage<TextContent>, Array<String>> |     scenarioReceiver: BehaviourContextAndTwoTypesReceiver<Unit, CommonMessage<TextContent>, Array<String>> | ||||||
| ) = command( | ) = command( | ||||||
|     commandRegex, |     commandRegex, | ||||||
|     requireOnlyCommandInMessage = false, |     requireOnlyCommandInMessage = false, | ||||||
|     initialFilter = initialFilter, |     initialFilter = initialFilter, | ||||||
|     updatesFilter = updatesFilter, |     subcontextUpdatesFilter = subcontextUpdatesFilter, | ||||||
|     markerFactory = markerFactory |     markerFactory = markerFactory | ||||||
| ) { | ) { | ||||||
|     val args = it.parseCommandsWithParams().let { commandsWithArgs -> |     val args = it.parseCommandsWithParams().let { commandsWithArgs -> | ||||||
| @@ -198,13 +198,13 @@ suspend fun BehaviourContext.commandWithArgs( | |||||||
| suspend fun BehaviourContext.commandWithArgs( | suspend fun BehaviourContext.commandWithArgs( | ||||||
|     command: String, |     command: String, | ||||||
|     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTwoTypesReceiver<Unit, CommonMessage<TextContent>, Array<String>> |     scenarioReceiver: BehaviourContextAndTwoTypesReceiver<Unit, CommonMessage<TextContent>, Array<String>> | ||||||
| ) = commandWithArgs( | ) = commandWithArgs( | ||||||
|     command.toRegex(), |     command.toRegex(), | ||||||
|     initialFilter = initialFilter, |     initialFilter = initialFilter, | ||||||
|     updatesFilter = updatesFilter, |     subcontextUpdatesFilter = subcontextUpdatesFilter, | ||||||
|     markerFactory = markerFactory, |     markerFactory = markerFactory, | ||||||
|     scenarioReceiver = scenarioReceiver |     scenarioReceiver = scenarioReceiver | ||||||
| ) | ) | ||||||
| @@ -212,15 +212,15 @@ suspend fun BehaviourContext.commandWithArgs( | |||||||
| suspend inline fun BehaviourContext.onCommandWithArgs( | suspend inline fun BehaviourContext.onCommandWithArgs( | ||||||
|     commandRegex: Regex, |     commandRegex: Regex, | ||||||
|     noinline initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     noinline initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     noinline updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     noinline subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     noinline scenarioReceiver: BehaviourContextAndTwoTypesReceiver<Unit, CommonMessage<TextContent>, Array<String>> |     noinline scenarioReceiver: BehaviourContextAndTwoTypesReceiver<Unit, CommonMessage<TextContent>, Array<String>> | ||||||
| ): Job = commandWithArgs(commandRegex, initialFilter, updatesFilter, markerFactory, scenarioReceiver) | ): Job = commandWithArgs(commandRegex, initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
| suspend inline fun BehaviourContext.onCommandWithArgs( | suspend inline fun BehaviourContext.onCommandWithArgs( | ||||||
|     command: String, |     command: String, | ||||||
|     noinline initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     noinline initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     noinline updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     noinline subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     noinline scenarioReceiver: BehaviourContextAndTwoTypesReceiver<Unit, CommonMessage<TextContent>, Array<String>> |     noinline scenarioReceiver: BehaviourContextAndTwoTypesReceiver<Unit, CommonMessage<TextContent>, Array<String>> | ||||||
| ): Job = onCommandWithArgs(command.toRegex(), initialFilter, updatesFilter, markerFactory, scenarioReceiver) | ): Job = onCommandWithArgs(command.toRegex(), initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|   | |||||||
| @@ -278,256 +278,485 @@ suspend fun BehaviourContext.onInvoice( | |||||||
| ) | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onContentMessage( | suspend fun BehaviourContext.onContentMessage( | ||||||
|     initialFilter: CommonMessageFilter<MessageContent>? = null, |     initialFilter: CommonMessageFilter<MessageContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MessageContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MessageContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<MessageContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<MessageContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MessageContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MessageContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onContact( | suspend fun BehaviourContext.onContact( | ||||||
|     initialFilter: CommonMessageFilter<ContactContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<ContactContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<ContactContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<ContactContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<ContactContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<ContactContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<ContactContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<ContactContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onDice( | suspend fun BehaviourContext.onDice( | ||||||
|     initialFilter: CommonMessageFilter<DiceContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<DiceContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DiceContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DiceContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<DiceContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<DiceContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DiceContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DiceContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onGame( | suspend fun BehaviourContext.onGame( | ||||||
|     initialFilter: CommonMessageFilter<GameContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<GameContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<GameContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<GameContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<GameContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<GameContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<GameContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<GameContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onLocation( | suspend fun BehaviourContext.onLocation( | ||||||
|     initialFilter: CommonMessageFilter<LocationContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<LocationContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<LocationContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<LocationContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<LocationContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<LocationContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<LocationContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<LocationContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onLiveLocation( | suspend fun BehaviourContext.onLiveLocation( | ||||||
|     initialFilter: CommonMessageFilter<LiveLocationContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<LiveLocationContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<LiveLocationContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<LiveLocationContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<LiveLocationContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<LiveLocationContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<LiveLocationContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<LiveLocationContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onStaticLocation( | suspend fun BehaviourContext.onStaticLocation( | ||||||
|     initialFilter: CommonMessageFilter<StaticLocationContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<StaticLocationContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<StaticLocationContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<StaticLocationContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<StaticLocationContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<StaticLocationContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<StaticLocationContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<StaticLocationContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onPoll( | suspend fun BehaviourContext.onPoll( | ||||||
|     initialFilter: CommonMessageFilter<PollContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<PollContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<PollContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<PollContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<PollContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<PollContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PollContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PollContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onText( | suspend fun BehaviourContext.onText( | ||||||
|     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVenue( | suspend fun BehaviourContext.onVenue( | ||||||
|     initialFilter: CommonMessageFilter<VenueContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<VenueContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VenueContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VenueContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<VenueContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<VenueContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VenueContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VenueContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onAudioMediaGroup( | suspend fun BehaviourContext.onAudioMediaGroup( | ||||||
|     initialFilter: CommonMessageFilter<AudioMediaGroupContent>? = null, |     initialFilter: CommonMessageFilter<AudioMediaGroupContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AudioMediaGroupContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AudioMediaGroupContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<AudioMediaGroupContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<AudioMediaGroupContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioMediaGroupContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioMediaGroupContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onDocumentMediaGroupContent( | suspend fun BehaviourContext.onDocumentMediaGroupContent( | ||||||
|     initialFilter: CommonMessageFilter<DocumentMediaGroupContent>? = null, |     initialFilter: CommonMessageFilter<DocumentMediaGroupContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DocumentMediaGroupContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DocumentMediaGroupContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<DocumentMediaGroupContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<DocumentMediaGroupContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentMediaGroupContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentMediaGroupContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onMediaCollection( | suspend fun BehaviourContext.onMediaCollection( | ||||||
|     initialFilter: CommonMessageFilter<MediaCollectionContent<TelegramMediaFile>>? = null, |     initialFilter: CommonMessageFilter<MediaCollectionContent<TelegramMediaFile>>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaCollectionContent<TelegramMediaFile>>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaCollectionContent<TelegramMediaFile>>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onMedia( | suspend fun BehaviourContext.onMedia( | ||||||
|     initialFilter: CommonMessageFilter<MediaContent>? = null, |     initialFilter: CommonMessageFilter<MediaContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MediaContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MediaContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<MediaContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<MediaContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onAnimation( | suspend fun BehaviourContext.onAnimation( | ||||||
|     initialFilter: CommonMessageFilter<AnimationContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<AnimationContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AnimationContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AnimationContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<AnimationContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<AnimationContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AnimationContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AnimationContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onAudio( | suspend fun BehaviourContext.onAudio( | ||||||
|     initialFilter: CommonMessageFilter<AudioContent>? = null, |     initialFilter: CommonMessageFilter<AudioContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AudioContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AudioContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<AudioContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<AudioContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onDocument( | suspend fun BehaviourContext.onDocument( | ||||||
|     initialFilter: CommonMessageFilter<DocumentContent>? = null, |     initialFilter: CommonMessageFilter<DocumentContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DocumentContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DocumentContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<DocumentContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<DocumentContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onPhoto( | suspend fun BehaviourContext.onPhoto( | ||||||
|     initialFilter: CommonMessageFilter<PhotoContent>? = null, |     initialFilter: CommonMessageFilter<PhotoContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<PhotoContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<PhotoContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<PhotoContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<PhotoContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PhotoContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PhotoContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onSticker( | suspend fun BehaviourContext.onSticker( | ||||||
|     initialFilter: CommonMessageFilter<StickerContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<StickerContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<StickerContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<StickerContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<StickerContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<StickerContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<StickerContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<StickerContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVideo( | suspend fun BehaviourContext.onVideo( | ||||||
|     initialFilter: CommonMessageFilter<VideoContent>? = null, |     initialFilter: CommonMessageFilter<VideoContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VideoContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VideoContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<VideoContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<VideoContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVideoNote( | suspend fun BehaviourContext.onVideoNote( | ||||||
|     initialFilter: CommonMessageFilter<VideoNoteContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<VideoNoteContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VideoNoteContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VideoNoteContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<VideoNoteContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<VideoNoteContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoNoteContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoNoteContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVoice( | suspend fun BehaviourContext.onVoice( | ||||||
|     initialFilter: CommonMessageFilter<VoiceContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<VoiceContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VoiceContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VoiceContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<VoiceContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<VoiceContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VoiceContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VoiceContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onInvoice( | suspend fun BehaviourContext.onInvoice( | ||||||
|     initialFilter: CommonMessageFilter<InvoiceContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<InvoiceContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<InvoiceContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<InvoiceContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<InvoiceContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<InvoiceContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<InvoiceContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<InvoiceContent>> | ||||||
| ) = onContent( | ) = onContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|   | |||||||
| @@ -1,4 +1,14 @@ | |||||||
| @file:Suppress("unused", "UNCHECKED_CAST") |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */@file:Suppress("unused", "UNCHECKED_CAST") | ||||||
|  |  | ||||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||||
|  |  | ||||||
| @@ -32,234 +42,444 @@ internal suspend inline fun <reified T : MessageContent> BehaviourContext.onEdit | |||||||
|     } ?.let(::listOfNotNull) |     } ?.let(::listOfNotNull) | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedContentMessage( | suspend fun BehaviourContext.onEditedContentMessage( | ||||||
|     initialFilter: CommonMessageFilter<MessageContent>? = null, |     initialFilter: CommonMessageFilter<MessageContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MessageContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MessageContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<MessageContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<MessageContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MessageContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MessageContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedContact( | suspend fun BehaviourContext.onEditedContact( | ||||||
|     initialFilter: CommonMessageFilter<ContactContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<ContactContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<ContactContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<ContactContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<ContactContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<ContactContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<ContactContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<ContactContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedDice( | suspend fun BehaviourContext.onEditedDice( | ||||||
|     initialFilter: CommonMessageFilter<DiceContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<DiceContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DiceContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DiceContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<DiceContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<DiceContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DiceContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DiceContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedGame( | suspend fun BehaviourContext.onEditedGame( | ||||||
|     initialFilter: CommonMessageFilter<GameContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<GameContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<GameContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<GameContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<GameContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<GameContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<GameContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<GameContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedLocation( | suspend fun BehaviourContext.onEditedLocation( | ||||||
|     initialFilter: CommonMessageFilter<LocationContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<LocationContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<LocationContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<LocationContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<LocationContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<LocationContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<LocationContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<LocationContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedPoll( | suspend fun BehaviourContext.onEditedPoll( | ||||||
|     initialFilter: CommonMessageFilter<PollContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<PollContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<PollContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<PollContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<PollContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<PollContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PollContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PollContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedText( | suspend fun BehaviourContext.onEditedText( | ||||||
|     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<TextContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<TextContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedVenue( | suspend fun BehaviourContext.onEditedVenue( | ||||||
|     initialFilter: CommonMessageFilter<VenueContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<VenueContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VenueContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VenueContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<VenueContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<VenueContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VenueContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VenueContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedAudioMediaGroup( | suspend fun BehaviourContext.onEditedAudioMediaGroup( | ||||||
|     initialFilter: CommonMessageFilter<AudioMediaGroupContent>? = null, |     initialFilter: CommonMessageFilter<AudioMediaGroupContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AudioMediaGroupContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AudioMediaGroupContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<AudioMediaGroupContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<AudioMediaGroupContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioMediaGroupContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioMediaGroupContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedDocumentMediaGroupContent( | suspend fun BehaviourContext.onEditedDocumentMediaGroupContent( | ||||||
|     initialFilter: CommonMessageFilter<DocumentMediaGroupContent>? = null, |     initialFilter: CommonMessageFilter<DocumentMediaGroupContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DocumentMediaGroupContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DocumentMediaGroupContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<DocumentMediaGroupContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<DocumentMediaGroupContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentMediaGroupContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentMediaGroupContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedMediaCollection( | suspend fun BehaviourContext.onEditedMediaCollection( | ||||||
|     initialFilter: CommonMessageFilter<MediaCollectionContent<TelegramMediaFile>>? = null, |     initialFilter: CommonMessageFilter<MediaCollectionContent<TelegramMediaFile>>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaCollectionContent<TelegramMediaFile>>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaCollectionContent<TelegramMediaFile>>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedMedia( | suspend fun BehaviourContext.onEditedMedia( | ||||||
|     initialFilter: CommonMessageFilter<MediaContent>? = null, |     initialFilter: CommonMessageFilter<MediaContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MediaContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<MediaContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<MediaContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<MediaContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedAnimation( | suspend fun BehaviourContext.onEditedAnimation( | ||||||
|     initialFilter: CommonMessageFilter<AnimationContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<AnimationContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AnimationContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AnimationContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<AnimationContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<AnimationContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AnimationContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AnimationContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedAudio( | suspend fun BehaviourContext.onEditedAudio( | ||||||
|     initialFilter: CommonMessageFilter<AudioContent>? = null, |     initialFilter: CommonMessageFilter<AudioContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AudioContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<AudioContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<AudioContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<AudioContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedDocument( | suspend fun BehaviourContext.onEditedDocument( | ||||||
|     initialFilter: CommonMessageFilter<DocumentContent>? = null, |     initialFilter: CommonMessageFilter<DocumentContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DocumentContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<DocumentContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<DocumentContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<DocumentContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedPhoto( | suspend fun BehaviourContext.onEditedPhoto( | ||||||
|     initialFilter: CommonMessageFilter<PhotoContent>? = null, |     initialFilter: CommonMessageFilter<PhotoContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<PhotoContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<PhotoContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<PhotoContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<PhotoContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PhotoContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PhotoContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedSticker( | suspend fun BehaviourContext.onEditedSticker( | ||||||
|     initialFilter: CommonMessageFilter<StickerContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<StickerContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<StickerContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<StickerContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<StickerContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<StickerContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<StickerContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<StickerContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedVideo( | suspend fun BehaviourContext.onEditedVideo( | ||||||
|     initialFilter: CommonMessageFilter<VideoContent>? = null, |     initialFilter: CommonMessageFilter<VideoContent>? = null, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VideoContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VideoContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<VideoContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<VideoContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedVideoNote( | suspend fun BehaviourContext.onEditedVideoNote( | ||||||
|     initialFilter: CommonMessageFilter<VideoNoteContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<VideoNoteContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VideoNoteContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VideoNoteContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<VideoNoteContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<VideoNoteContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoNoteContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoNoteContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedVoice( | suspend fun BehaviourContext.onEditedVoice( | ||||||
|     initialFilter: CommonMessageFilter<VoiceContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<VoiceContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VoiceContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<VoiceContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<VoiceContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<VoiceContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VoiceContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VoiceContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onEditedInvoice( | suspend fun BehaviourContext.onEditedInvoice( | ||||||
|     initialFilter: CommonMessageFilter<InvoiceContent>? = CommonMessageFilterExcludeMediaGroups, |     initialFilter: CommonMessageFilter<InvoiceContent>? = CommonMessageFilterExcludeMediaGroups, | ||||||
|     updatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<InvoiceContent>, Update> = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, CommonMessage<InvoiceContent>, Update> = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in CommonMessage<InvoiceContent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in CommonMessage<InvoiceContent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<InvoiceContent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<InvoiceContent>> | ||||||
| )= onEditedContent( | )= onEditedContent( | ||||||
|     initialFilter, |     initialFilter, | ||||||
|     updatesFilter, |     subcontextUpdatesFilter, | ||||||
|     markerFactory, |     markerFactory, | ||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|   | |||||||
| @@ -147,60 +147,160 @@ suspend fun BehaviourContext.onSupergroupChatCreated( | |||||||
| ) = onEvent(additionalFilter, if (includeFilterByChatInBehaviourSubContext) MessageFilterByChat else null, markerFactory, scenarioReceiver) | ) = onEvent(additionalFilter, if (includeFilterByChatInBehaviourSubContext) MessageFilterByChat else null, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onChannelEvent( | suspend fun BehaviourContext.onChannelEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<ChannelEvent>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<ChannelEvent>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<ChannelEvent>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<ChannelEvent>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<ChannelEvent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<ChannelEvent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChannelEvent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChannelEvent>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onChatEvent( | suspend fun BehaviourContext.onChatEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<ChatEvent>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<ChatEvent>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<ChatEvent>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<ChatEvent>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<ChatEvent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<ChatEvent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChatEvent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChatEvent>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVoiceChatEvent( | suspend fun BehaviourContext.onVoiceChatEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<VoiceChatEvent>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<VoiceChatEvent>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<VoiceChatEvent>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<VoiceChatEvent>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatEvent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatEvent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatEvent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatEvent>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVoiceChatStartedEvent( | suspend fun BehaviourContext.onVoiceChatStartedEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<VoiceChatStarted>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<VoiceChatStarted>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<VoiceChatStarted>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<VoiceChatStarted>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatStarted>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatStarted>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatStarted>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatStarted>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVoiceChatEndedEvent( | suspend fun BehaviourContext.onVoiceChatEndedEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<VoiceChatEnded>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<VoiceChatEnded>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<VoiceChatEnded>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<VoiceChatEnded>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatEnded>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatEnded>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatEnded>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatEnded>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVoiceChatParticipantsInvitedEvent( | suspend fun BehaviourContext.onVoiceChatParticipantsInvitedEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<VoiceChatParticipantsInvited>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<VoiceChatParticipantsInvited>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<VoiceChatParticipantsInvited>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<VoiceChatParticipantsInvited>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatParticipantsInvited>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatParticipantsInvited>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatParticipantsInvited>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatParticipantsInvited>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onMessageAutoDeleteTimerChangedEvent( | suspend fun BehaviourContext.onMessageAutoDeleteTimerChangedEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<MessageAutoDeleteTimerChanged>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<MessageAutoDeleteTimerChanged>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<MessageAutoDeleteTimerChanged>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<MessageAutoDeleteTimerChanged>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<MessageAutoDeleteTimerChanged>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<MessageAutoDeleteTimerChanged>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<MessageAutoDeleteTimerChanged>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<MessageAutoDeleteTimerChanged>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onCommonEvent( | suspend fun BehaviourContext.onCommonEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<CommonEvent>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<CommonEvent>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<CommonEvent>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<CommonEvent>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<CommonEvent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<CommonEvent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<CommonEvent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<CommonEvent>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onGroupEvent( | suspend fun BehaviourContext.onGroupEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<GroupEvent>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<GroupEvent>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<GroupEvent>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<GroupEvent>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<GroupEvent>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<GroupEvent>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<GroupEvent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<GroupEvent>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onSupergroupEvent( | suspend fun BehaviourContext.onSupergroupEvent( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<SupergroupEvent>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<SupergroupEvent>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<SupergroupEvent>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<SupergroupEvent>, Update>? = MessageFilterByChat, | ||||||
| @@ -208,60 +308,159 @@ suspend fun BehaviourContext.onSupergroupEvent( | |||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<SupergroupEvent>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<SupergroupEvent>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onChannelChatCreated( | suspend fun BehaviourContext.onChannelChatCreated( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<ChannelChatCreated>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<ChannelChatCreated>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<ChannelChatCreated>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<ChannelChatCreated>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<ChannelChatCreated>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<ChannelChatCreated>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChannelChatCreated>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChannelChatCreated>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onDeleteChatPhoto( | suspend fun BehaviourContext.onDeleteChatPhoto( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<DeleteChatPhoto>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<DeleteChatPhoto>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<DeleteChatPhoto>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<DeleteChatPhoto>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<DeleteChatPhoto>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<DeleteChatPhoto>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<DeleteChatPhoto>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<DeleteChatPhoto>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onGroupChatCreated( | suspend fun BehaviourContext.onGroupChatCreated( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<GroupChatCreated>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<GroupChatCreated>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<GroupChatCreated>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<GroupChatCreated>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<GroupChatCreated>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<GroupChatCreated>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<GroupChatCreated>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<GroupChatCreated>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onLeftChatMember( | suspend fun BehaviourContext.onLeftChatMember( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<LeftChatMember>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<LeftChatMember>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<LeftChatMember>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<LeftChatMember>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<LeftChatMember>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<LeftChatMember>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<LeftChatMember>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<LeftChatMember>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onNewChatMembers( | suspend fun BehaviourContext.onNewChatMembers( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<NewChatMembers>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<NewChatMembers>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<NewChatMembers>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<NewChatMembers>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<NewChatMembers>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<NewChatMembers>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatMembers>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatMembers>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onNewChatPhoto( | suspend fun BehaviourContext.onNewChatPhoto( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<NewChatPhoto>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<NewChatPhoto>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<NewChatPhoto>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<NewChatPhoto>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<NewChatPhoto>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<NewChatPhoto>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatPhoto>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatPhoto>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onNewChatTitle( | suspend fun BehaviourContext.onNewChatTitle( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<NewChatTitle>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<NewChatTitle>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<NewChatTitle>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<NewChatTitle>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<NewChatTitle>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<NewChatTitle>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatTitle>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatTitle>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onPinnedMessage( | suspend fun BehaviourContext.onPinnedMessage( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<PinnedMessage>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<PinnedMessage>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<PinnedMessage>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<PinnedMessage>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<PinnedMessage>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<PinnedMessage>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<PinnedMessage>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<PinnedMessage>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onProximityAlertTriggered( | suspend fun BehaviourContext.onProximityAlertTriggered( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<ProximityAlertTriggered>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<ProximityAlertTriggered>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<ProximityAlertTriggered>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<ProximityAlertTriggered>, Update>? = MessageFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in ChatEventMessage<ProximityAlertTriggered>, Any> = ByChatMessageMarkerFactory, |     markerFactory: MarkerFactory<in ChatEventMessage<ProximityAlertTriggered>, Any> = ByChatMessageMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ProximityAlertTriggered>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ProximityAlertTriggered>> | ||||||
| ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onEvent(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onSupergroupChatCreated( | suspend fun BehaviourContext.onSupergroupChatCreated( | ||||||
|     initialFilter: SimpleFilter<ChatEventMessage<SupergroupChatCreated>>? = null, |     initialFilter: SimpleFilter<ChatEventMessage<SupergroupChatCreated>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<SupergroupChatCreated>, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, ChatEventMessage<SupergroupChatCreated>, Update>? = MessageFilterByChat, | ||||||
|   | |||||||
| @@ -41,6 +41,16 @@ suspend fun BehaviourContext.onLocationInlineQuery( | |||||||
| ) = onInlineQuery(additionalFilter, if (includeFilterByChatInBehaviourSubContext) InlineQueryFilterByUser else null, markerFactory, scenarioReceiver) | ) = onInlineQuery(additionalFilter, if (includeFilterByChatInBehaviourSubContext) InlineQueryFilterByUser else null, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onAnyInlineQuery( | suspend fun BehaviourContext.onAnyInlineQuery( | ||||||
|     initialFilter: SimpleFilter<InlineQuery>? = null, |     initialFilter: SimpleFilter<InlineQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, InlineQuery, Update>? = InlineQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, InlineQuery, Update>? = InlineQueryFilterByUser, | ||||||
| @@ -48,6 +58,16 @@ suspend fun BehaviourContext.onAnyInlineQuery( | |||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, InlineQuery> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, InlineQuery> | ||||||
| ) = onInlineQuery(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onInlineQuery(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onBaseInlineQuery( | suspend fun BehaviourContext.onBaseInlineQuery( | ||||||
|     initialFilter: SimpleFilter<BaseInlineQuery>? = null, |     initialFilter: SimpleFilter<BaseInlineQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, BaseInlineQuery, Update>? = InlineQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, BaseInlineQuery, Update>? = InlineQueryFilterByUser, | ||||||
| @@ -55,6 +75,16 @@ suspend fun BehaviourContext.onBaseInlineQuery( | |||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, BaseInlineQuery> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, BaseInlineQuery> | ||||||
| ) = onInlineQuery(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onInlineQuery(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onLocationInlineQuery( | suspend fun BehaviourContext.onLocationInlineQuery( | ||||||
|     initialFilter: SimpleFilter<LocationInlineQuery>? = null, |     initialFilter: SimpleFilter<LocationInlineQuery>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, LocationInlineQuery, Update>? = InlineQueryFilterByUser, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, LocationInlineQuery, Update>? = InlineQueryFilterByUser, | ||||||
|   | |||||||
| @@ -69,42 +69,112 @@ suspend fun BehaviourContext.onVideoGallery( | |||||||
| ) = buildMediaGroupTrigger(additionalFilter, if (includeFilterByChatInBehaviourSubContext) MessagesFilterByChat else null, markerFactory, scenarioReceiver) | ) = buildMediaGroupTrigger(additionalFilter, if (includeFilterByChatInBehaviourSubContext) MessagesFilterByChat else null, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onMediaGroup( | suspend fun BehaviourContext.onMediaGroup( | ||||||
|     initialFilter: SimpleFilter<List<MediaGroupMessage<MediaGroupContent>>>? = null, |     initialFilter: SimpleFilter<List<MediaGroupMessage<MediaGroupContent>>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<MediaGroupContent>>, Update>? = MessagesFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<MediaGroupContent>>, Update>? = MessagesFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<MediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, |     markerFactory: MarkerFactory<in List<MediaGroupMessage<MediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<MediaGroupContent>>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<MediaGroupContent>>> | ||||||
| ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onPlaylist( | suspend fun BehaviourContext.onPlaylist( | ||||||
|     initialFilter: SimpleFilter<List<MediaGroupMessage<AudioMediaGroupContent>>>? = null, |     initialFilter: SimpleFilter<List<MediaGroupMessage<AudioMediaGroupContent>>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<AudioMediaGroupContent>>, Update>? = MessagesFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<AudioMediaGroupContent>>, Update>? = MessagesFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<AudioMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, |     markerFactory: MarkerFactory<in List<MediaGroupMessage<AudioMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<AudioMediaGroupContent>>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<AudioMediaGroupContent>>> | ||||||
| ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onDocumentsGroup( | suspend fun BehaviourContext.onDocumentsGroup( | ||||||
|     initialFilter: SimpleFilter<List<MediaGroupMessage<DocumentMediaGroupContent>>>? = null, |     initialFilter: SimpleFilter<List<MediaGroupMessage<DocumentMediaGroupContent>>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<DocumentMediaGroupContent>>, Update>? = MessagesFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<DocumentMediaGroupContent>>, Update>? = MessagesFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<DocumentMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, |     markerFactory: MarkerFactory<in List<MediaGroupMessage<DocumentMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<DocumentMediaGroupContent>>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<DocumentMediaGroupContent>>> | ||||||
| ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVisualGallery( | suspend fun BehaviourContext.onVisualGallery( | ||||||
|     initialFilter: SimpleFilter<List<MediaGroupMessage<VisualMediaGroupContent>>>? = null, |     initialFilter: SimpleFilter<List<MediaGroupMessage<VisualMediaGroupContent>>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<VisualMediaGroupContent>>, Update>? = MessagesFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<VisualMediaGroupContent>>, Update>? = MessagesFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<VisualMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, |     markerFactory: MarkerFactory<in List<MediaGroupMessage<VisualMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<VisualMediaGroupContent>>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<VisualMediaGroupContent>>> | ||||||
| ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVisualMediaGroup( | suspend fun BehaviourContext.onVisualMediaGroup( | ||||||
|     initialFilter: SimpleFilter<List<MediaGroupMessage<VisualMediaGroupContent>>>? = null, |     initialFilter: SimpleFilter<List<MediaGroupMessage<VisualMediaGroupContent>>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<VisualMediaGroupContent>>, Update>? = MessagesFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<VisualMediaGroupContent>>, Update>? = MessagesFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<VisualMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, |     markerFactory: MarkerFactory<in List<MediaGroupMessage<VisualMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<VisualMediaGroupContent>>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<VisualMediaGroupContent>>> | ||||||
| ) = onVisualGallery(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = onVisualGallery(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onPhotoGallery( | suspend fun BehaviourContext.onPhotoGallery( | ||||||
|     initialFilter: SimpleFilter<List<MediaGroupMessage<PhotoContent>>>? = null, |     initialFilter: SimpleFilter<List<MediaGroupMessage<PhotoContent>>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<PhotoContent>>, Update>? = MessagesFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<PhotoContent>>, Update>? = MessagesFilterByChat, | ||||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<PhotoContent>>, Any> = ByChatMediaGroupMarkerFactory, |     markerFactory: MarkerFactory<in List<MediaGroupMessage<PhotoContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<PhotoContent>>> |     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<PhotoContent>>> | ||||||
| ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ) = buildMediaGroupTrigger(initialFilter, subcontextUpdatesFilter, markerFactory, scenarioReceiver) | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onVideoGallery( | suspend fun BehaviourContext.onVideoGallery( | ||||||
|     initialFilter: SimpleFilter<List<MediaGroupMessage<VideoContent>>>? = null, |     initialFilter: SimpleFilter<List<MediaGroupMessage<VideoContent>>>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<VideoContent>>, Update>? = MessagesFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, List<MediaGroupMessage<VideoContent>>, Update>? = MessagesFilterByChat, | ||||||
|   | |||||||
| @@ -32,6 +32,16 @@ suspend fun BehaviourContext.onPassportMessage( | |||||||
|     scenarioReceiver |     scenarioReceiver | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @param initialFilter This filter will be called to remove unnecessary data BEFORE [scenarioReceiver] call | ||||||
|  |  * @param subcontextUpdatesFilter This filter will be applied to each update inside of [scenarioReceiver]. For example, | ||||||
|  |  * this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage] | ||||||
|  |  * @param [markerFactory] Will be used to identify different "stream". [scenarioReceiver] will be called synchronously | ||||||
|  |  * in one "stream". Output of [markerFactory] will be used as a key for "stream" | ||||||
|  |  * @param scenarioReceiver Main callback which will be used to handle incoming data if [initialFilter] will pass that | ||||||
|  |  * data | ||||||
|  |  */ | ||||||
| suspend fun BehaviourContext.onPassportMessage( | suspend fun BehaviourContext.onPassportMessage( | ||||||
|     initialFilter: SimpleFilter<PassportMessage>? = null, |     initialFilter: SimpleFilter<PassportMessage>? = null, | ||||||
|     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, PassportMessage, Update>? = MessageFilterByChat, |     subcontextUpdatesFilter: BehaviourContextAndTwoTypesReceiver<Boolean, PassportMessage, Update>? = MessageFilterByChat, | ||||||
|   | |||||||
| @@ -32,6 +32,7 @@ import dev.inmo.tgbotapi.types.chat.abstracts.extended.* | |||||||
| import dev.inmo.tgbotapi.types.dice.* | import dev.inmo.tgbotapi.types.dice.* | ||||||
| import dev.inmo.tgbotapi.types.files.* | import dev.inmo.tgbotapi.types.files.* | ||||||
| import dev.inmo.tgbotapi.types.files.abstracts.* | import dev.inmo.tgbotapi.types.files.abstracts.* | ||||||
|  | import dev.inmo.tgbotapi.types.location.* | ||||||
| import dev.inmo.tgbotapi.types.message.* | import dev.inmo.tgbotapi.types.message.* | ||||||
| import dev.inmo.tgbotapi.types.message.ChatEvents.* | import dev.inmo.tgbotapi.types.message.ChatEvents.* | ||||||
| import dev.inmo.tgbotapi.types.message.ChatEvents.LeftChatMember | import dev.inmo.tgbotapi.types.message.ChatEvents.LeftChatMember | ||||||
| @@ -3134,3 +3135,21 @@ inline fun Any.asWithOptionalLanguageCode(): WithOptionalLanguageCode? = this as | |||||||
|  |  | ||||||
| @PreviewFeature | @PreviewFeature | ||||||
| inline fun Any.requireWithOptionalLanguageCode(): WithOptionalLanguageCode = this as WithOptionalLanguageCode | inline fun Any.requireWithOptionalLanguageCode(): WithOptionalLanguageCode = this as WithOptionalLanguageCode | ||||||
|  |  | ||||||
|  | @PreviewFeature | ||||||
|  | inline fun <T> Location.whenStaticLocation(block: (StaticLocation) -> T) = asStaticLocation() ?.let(block) | ||||||
|  |  | ||||||
|  | @PreviewFeature | ||||||
|  | inline fun Location.asStaticLocation(): StaticLocation? = this as? StaticLocation | ||||||
|  |  | ||||||
|  | @PreviewFeature | ||||||
|  | inline fun Location.requireStaticLocation(): StaticLocation = this as StaticLocation | ||||||
|  |  | ||||||
|  | @PreviewFeature | ||||||
|  | inline fun <T> Location.whenLiveLocation(block: (LiveLocation) -> T) = asLiveLocation() ?.let(block) | ||||||
|  |  | ||||||
|  | @PreviewFeature | ||||||
|  | inline fun Location.asLiveLocation(): LiveLocation? = this as? LiveLocation | ||||||
|  |  | ||||||
|  | @PreviewFeature | ||||||
|  | inline fun Location.requireLiveLocation(): LiveLocation = this as LiveLocation | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user