mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 09:10:07 +00:00 
			
		
		
		
	rewrite to use subscribeSafelyWithoutExceptionsAsync in triggers of behaviour builder
This commit is contained in:
		| @@ -1,20 +1,18 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||
|  | ||||
|  | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptions | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptionsAsync | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.* | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.expectFlow | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.optionallyWrapWithLaunch | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByUserCallbackQueryMarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.utils.asCallbackQueryUpdate | ||||
| import dev.inmo.tgbotapi.extensions.utils.extensions.sourceChat | ||||
| import dev.inmo.tgbotapi.types.CallbackQuery.* | ||||
| import kotlinx.coroutines.Job | ||||
| import kotlinx.coroutines.launch | ||||
|  | ||||
| internal suspend inline fun <reified T : CallbackQuery> BehaviourContext.onCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     noinline additionalFilter: (suspend (T) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in T, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, T> | ||||
| ) = flowsUpdatesFilter.expectFlow(bot) { | ||||
|     it.asCallbackQueryUpdate() ?.data ?.let { query -> | ||||
| @@ -24,75 +22,75 @@ internal suspend inline fun <reified T : CallbackQuery> BehaviourContext.onCallb | ||||
|             null | ||||
|         } | ||||
|     }.let(::listOfNotNull) | ||||
| }.subscribeSafelyWithoutExceptions( | ||||
| }.subscribeSafelyWithoutExceptionsAsync( | ||||
|     scope, | ||||
|     optionallyWrapWithLaunch(performInParallel) { triggerQuery -> | ||||
|         doInSubContextWithUpdatesFilter( | ||||
|             updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|                 { it.sourceChat() ?.id ?.chatId == triggerQuery.user.id.chatId } | ||||
|             } else { | ||||
|                 null | ||||
|             }, | ||||
|             stopOnCompletion = false | ||||
|         ) { | ||||
|             scenarioReceiver(triggerQuery) | ||||
|         } | ||||
|     markerFactory::invoke | ||||
| ) { triggerQuery -> | ||||
|     doInSubContextWithUpdatesFilter( | ||||
|         updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|             { it.sourceChat() ?.id ?.chatId == triggerQuery.user.id.chatId } | ||||
|         } else { | ||||
|             null | ||||
|         }, | ||||
|         stopOnCompletion = false | ||||
|     ) { | ||||
|         scenarioReceiver(triggerQuery) | ||||
|     } | ||||
| ) | ||||
| } | ||||
|  | ||||
|  | ||||
| suspend fun BehaviourContext.onDataCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (DataCallbackQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in DataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, DataCallbackQuery> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|  | ||||
| suspend fun BehaviourContext.onGameShortNameCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (GameShortNameCallbackQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in GameShortNameCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, GameShortNameCallbackQuery> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onInlineMessageIdCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (InlineMessageIdCallbackQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in InlineMessageIdCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, InlineMessageIdCallbackQuery> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onInlineMessageIdDataCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (InlineMessageIdDataCallbackQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in InlineMessageIdDataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, InlineMessageIdDataCallbackQuery> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onInlineMessageIdGameShortNameCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (InlineMessageIdGameShortNameCallbackQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in InlineMessageIdGameShortNameCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, InlineMessageIdGameShortNameCallbackQuery> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onMessageCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (MessageCallbackQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in MessageCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, MessageCallbackQuery> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onMessageDataCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (MessageDataCallbackQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in MessageDataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, MessageDataCallbackQuery> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onMessageGameShortNameCallbackQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (MessageGameShortNameCallbackQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in MessageGameShortNameCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, MessageGameShortNameCallbackQuery> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onUnknownCallbackQueryType( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (UnknownCallbackQueryType) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in UnknownCallbackQueryType, Any> = ByUserCallbackQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, UnknownCallbackQueryType> | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onCallbackQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|   | ||||
| @@ -1,74 +1,73 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||
|  | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptions | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelySkippingExceptionsAsync | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.* | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.expectFlow | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.optionallyWrapWithLaunch | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByChatChatMemberUpdatedMarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.utils.extensions.sourceChat | ||||
| import dev.inmo.tgbotapi.types.ChatMemberUpdated | ||||
| import dev.inmo.tgbotapi.types.update.CommonChatMemberUpdatedUpdate | ||||
| import dev.inmo.tgbotapi.types.update.MyChatMemberUpdatedUpdate | ||||
| import dev.inmo.tgbotapi.types.update.abstracts.ChatMemberUpdatedUpdate | ||||
| import kotlinx.coroutines.Job | ||||
| import kotlinx.coroutines.launch | ||||
|  | ||||
| internal suspend inline fun <reified U : ChatMemberUpdatedUpdate> BehaviourContext.onChatMemberUpdatedInternal( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     noinline additionalFilter: (suspend (ChatMemberUpdated) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<ChatMemberUpdated, Any> = ByChatChatMemberUpdatedMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatMemberUpdated> | ||||
| ) = flowsUpdatesFilter.expectFlow(bot) { | ||||
|     (it as? U) ?.data ?.let { chatMemberUpdated -> | ||||
|         if (additionalFilter == null || additionalFilter(chatMemberUpdated)) chatMemberUpdated else null | ||||
|     }.let(::listOfNotNull) | ||||
| }.subscribeSafelyWithoutExceptions( | ||||
| }.subscribeSafelySkippingExceptionsAsync( | ||||
|     scope, | ||||
|     optionallyWrapWithLaunch(performInParallel) { triggerChatMemberUpdated -> | ||||
|         doInSubContextWithUpdatesFilter( | ||||
|             updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|                 { it.sourceChat() ?.id ?.chatId == triggerChatMemberUpdated.chat.id.chatId } | ||||
|             } else { | ||||
|                 null | ||||
|             }, | ||||
|             stopOnCompletion = false | ||||
|         ) { | ||||
|             scenarioReceiver(triggerChatMemberUpdated) | ||||
|         } | ||||
|     markerFactory::invoke | ||||
| ) { triggerChatMemberUpdated -> | ||||
|     doInSubContextWithUpdatesFilter( | ||||
|         updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|             { it.sourceChat() ?.id ?.chatId == triggerChatMemberUpdated.chat.id.chatId } | ||||
|         } else { | ||||
|             null | ||||
|         }, | ||||
|         stopOnCompletion = false | ||||
|     ) { | ||||
|         scenarioReceiver(triggerChatMemberUpdated) | ||||
|     } | ||||
| ) | ||||
| } | ||||
|  | ||||
| suspend fun BehaviourContext.onChatMemberUpdated( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatMemberUpdated) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<ChatMemberUpdated, Any> = ByChatChatMemberUpdatedMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatMemberUpdated> | ||||
| ) = onChatMemberUpdatedInternal<ChatMemberUpdatedUpdate>( | ||||
|     includeFilterByChatInBehaviourSubContext, | ||||
|     additionalFilter, | ||||
|     performInParallel, | ||||
|     markerFactory, | ||||
|     scenarioReceiver | ||||
| ) | ||||
|  | ||||
| suspend fun BehaviourContext.onCommonChatMemberUpdated( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatMemberUpdated) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<ChatMemberUpdated, Any> = ByChatChatMemberUpdatedMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatMemberUpdated> | ||||
| ) = onChatMemberUpdatedInternal<CommonChatMemberUpdatedUpdate>( | ||||
|     includeFilterByChatInBehaviourSubContext, | ||||
|     additionalFilter, | ||||
|     performInParallel, | ||||
|     markerFactory, | ||||
|     scenarioReceiver | ||||
| ) | ||||
|  | ||||
| suspend fun BehaviourContext.onMyChatMemberUpdated( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatMemberUpdated) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<ChatMemberUpdated, Any> = ByChatChatMemberUpdatedMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatMemberUpdated> | ||||
| ) = onChatMemberUpdatedInternal<MyChatMemberUpdatedUpdate>( | ||||
|     includeFilterByChatInBehaviourSubContext, | ||||
|     additionalFilter, | ||||
|     performInParallel, | ||||
|     markerFactory, | ||||
|     scenarioReceiver | ||||
| ) | ||||
|   | ||||
| @@ -2,6 +2,8 @@ package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||
|  | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContext | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTypeReceiver | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByChatMessageMarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.utils.asBotCommandTextSource | ||||
| import dev.inmo.tgbotapi.types.message.abstracts.CommonMessage | ||||
| import dev.inmo.tgbotapi.types.message.content.TextContent | ||||
| @@ -12,7 +14,7 @@ suspend fun BehaviourContext.command( | ||||
|     requireOnlyCommandInMessage: Boolean = true, | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<TextContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||
| ): Job = onText( | ||||
|     includeFilterByChatInBehaviourSubContext, | ||||
| @@ -28,7 +30,7 @@ suspend fun BehaviourContext.command( | ||||
|             commandRegex.matches(it.asBotCommandTextSource() ?.command ?: return@any false) | ||||
|         } && (additionalFilter ?.invoke(message) != false) | ||||
|     }, | ||||
|     performInParallel, | ||||
|     markerFactory, | ||||
|     scenarioReceiver | ||||
| ) | ||||
| suspend fun BehaviourContext.command( | ||||
| @@ -36,24 +38,24 @@ suspend fun BehaviourContext.command( | ||||
|     requireOnlyCommandInMessage: Boolean = true, | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<TextContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||
| ) = command(command.toRegex(), requireOnlyCommandInMessage, includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = command(command.toRegex(), requireOnlyCommandInMessage, includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|  | ||||
| suspend inline fun BehaviourContext.onCommand( | ||||
|     commandRegex: Regex, | ||||
|     requireOnlyCommandInMessage: Boolean = true, | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     noinline additionalFilter: CommonMessageFilter<TextContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||
| ): Job = command(commandRegex, requireOnlyCommandInMessage, includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ): Job = command(commandRegex, requireOnlyCommandInMessage, includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|  | ||||
| suspend inline fun BehaviourContext.onCommand( | ||||
|     command: String, | ||||
|     requireOnlyCommandInMessage: Boolean = true, | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     noinline additionalFilter: CommonMessageFilter<TextContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||
| ): Job = onCommand(command.toRegex(), requireOnlyCommandInMessage, includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ): Job = onCommand(command.toRegex(), requireOnlyCommandInMessage, includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|   | ||||
| @@ -2,10 +2,11 @@ | ||||
|  | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||
|  | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptions | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptionsAsync | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.* | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.expectFlow | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.optionallyWrapWithLaunch | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByChatMessageMarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.utils.* | ||||
| import dev.inmo.tgbotapi.extensions.utils.extensions.sourceChat | ||||
| import dev.inmo.tgbotapi.types.files.abstracts.TelegramMediaFile | ||||
| @@ -23,7 +24,7 @@ internal suspend inline fun <reified T : MessageContent> BehaviourContext.onCont | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     includeMediaGroups: Boolean = true, | ||||
|     noinline additionalFilter: CommonMessageFilter<T>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<T>, Any> = ByChatMessageMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<T>> | ||||
| ) = flowsUpdatesFilter.expectFlow(bot) { | ||||
|     if (includeMediaGroups) { | ||||
| @@ -46,152 +47,152 @@ internal suspend inline fun <reified T : MessageContent> BehaviourContext.onCont | ||||
|             null | ||||
|         } | ||||
|     }.let(::listOfNotNull) | ||||
| }.subscribeSafelyWithoutExceptions( | ||||
| }.subscribeSafelyWithoutExceptionsAsync( | ||||
|     scope, | ||||
|     optionallyWrapWithLaunch(performInParallel) { triggerMessage -> | ||||
|         doInSubContextWithUpdatesFilter( | ||||
|             updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|                 { it.sourceChat() ?.id ?.chatId == triggerMessage.chat.id.chatId } | ||||
|             } else { | ||||
|                 null | ||||
|             }, | ||||
|             stopOnCompletion = false | ||||
|         ) { | ||||
|             scenarioReceiver(triggerMessage) | ||||
|         } | ||||
|     markerFactory::invoke | ||||
| ) { triggerMessage -> | ||||
|     doInSubContextWithUpdatesFilter( | ||||
|         updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|             { it.sourceChat() ?.id ?.chatId == triggerMessage.chat.id.chatId } | ||||
|         } else { | ||||
|             null | ||||
|         }, | ||||
|         stopOnCompletion = false | ||||
|     ) { | ||||
|         scenarioReceiver(triggerMessage) | ||||
|     } | ||||
| ) | ||||
| } | ||||
|  | ||||
| suspend fun BehaviourContext.onContentMessage( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<MessageContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<MessageContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MessageContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onContact( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<ContactContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<ContactContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<ContactContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onDice( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<DiceContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<DiceContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DiceContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onGame( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<GameContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<GameContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<GameContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onLocation( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<LocationContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<LocationContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<LocationContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onPoll( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<PollContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<PollContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PollContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onText( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<TextContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<TextContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<TextContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVenue( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<VenueContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<VenueContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VenueContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onAudioMediaGroup( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<AudioMediaGroupContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<AudioMediaGroupContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioMediaGroupContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, true, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, true, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onDocumentMediaGroupContent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     includeMediaGroups: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<DocumentMediaGroupContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<DocumentMediaGroupContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentMediaGroupContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onMediaCollection( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     includeMediaGroups: Boolean = false, | ||||
|     additionalFilter: (suspend (CommonMessage<MediaCollectionContent<TelegramMediaFile>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<MediaCollectionContent<TelegramMediaFile>>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaCollectionContent<TelegramMediaFile>>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onMedia( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     includeMediaGroups: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<MediaContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<MediaContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<MediaContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onAnimation( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<AnimationContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<AnimationContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AnimationContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onAudio( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     includeMediaGroups: Boolean = false, | ||||
|     additionalFilter: CommonMessageFilter<AudioContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<AudioContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<AudioContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onDocument( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     includeMediaGroups: Boolean = false, | ||||
|     additionalFilter: CommonMessageFilter<DocumentContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<DocumentContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<DocumentContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onPhoto( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     includeMediaGroups: Boolean = false, | ||||
|     additionalFilter: CommonMessageFilter<PhotoContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<PhotoContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<PhotoContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onSticker( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<StickerContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<StickerContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<StickerContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVideo( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     includeMediaGroups: Boolean = false, | ||||
|     additionalFilter: CommonMessageFilter<VideoContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<VideoContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, includeMediaGroups, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVideoNote( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<VideoNoteContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<VideoNoteContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VideoNoteContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVoice( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<VoiceContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<VoiceContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<VoiceContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onInvoice( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: CommonMessageFilter<InvoiceContent>? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in CommonMessage<InvoiceContent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, CommonMessage<InvoiceContent>> | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onContent(includeFilterByChatInBehaviourSubContext, false, additionalFilter, markerFactory, scenarioReceiver) | ||||
|   | ||||
| @@ -1,10 +1,11 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||
|  | ||||
|  | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptions | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptionsAsync | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.* | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.expectFlow | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.optionallyWrapWithLaunch | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByChatMessageMarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.utils.asBaseSentMessageUpdate | ||||
| import dev.inmo.tgbotapi.extensions.utils.asChatEventMessage | ||||
| import dev.inmo.tgbotapi.extensions.utils.extensions.sourceChat | ||||
| @@ -16,7 +17,7 @@ import dev.inmo.tgbotapi.types.message.abstracts.ChatEventMessage | ||||
| internal suspend inline fun <reified T : ChatEvent> BehaviourContext.onEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     noinline additionalFilter: (suspend (ChatEventMessage<T>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<T>, Any> = ByChatMessageMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<T>> | ||||
| ) = flowsUpdatesFilter.expectFlow(bot) { | ||||
|     it.asBaseSentMessageUpdate() ?.data ?.asChatEventMessage() ?.let { message -> | ||||
| @@ -27,138 +28,138 @@ internal suspend inline fun <reified T : ChatEvent> BehaviourContext.onEvent( | ||||
|             null | ||||
|         } | ||||
|     }.let(::listOfNotNull) | ||||
| }.subscribeSafelyWithoutExceptions( | ||||
| }.subscribeSafelyWithoutExceptionsAsync( | ||||
|     scope, | ||||
|     optionallyWrapWithLaunch(performInParallel) { triggerMessage -> | ||||
|         doInSubContextWithUpdatesFilter( | ||||
|             updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|                 { it.sourceChat() ?.id ?.chatId == triggerMessage.chat.id.chatId } | ||||
|             } else null, | ||||
|             stopOnCompletion = false | ||||
|         ) { | ||||
|             scenarioReceiver(triggerMessage) | ||||
|         } | ||||
|     markerFactory::invoke | ||||
| ) { triggerMessage -> | ||||
|     doInSubContextWithUpdatesFilter( | ||||
|         updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|             { it.sourceChat() ?.id ?.chatId == triggerMessage.chat.id.chatId } | ||||
|         } else null, | ||||
|         stopOnCompletion = false | ||||
|     ) { | ||||
|         scenarioReceiver(triggerMessage) | ||||
|     } | ||||
| ) | ||||
| } | ||||
|  | ||||
| suspend fun BehaviourContext.onChannelEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<ChannelEvent>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<ChannelEvent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChannelEvent>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onChatEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<ChatEvent>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<ChatEvent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChatEvent>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVoiceChatEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<VoiceChatEvent>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatEvent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatEvent>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVoiceChatStartedEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<VoiceChatStarted>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatStarted>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatStarted>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVoiceChatEndedEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<VoiceChatEnded>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatEnded>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatEnded>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVoiceChatParticipantsInvitedEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<VoiceChatParticipantsInvited>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<VoiceChatParticipantsInvited>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<VoiceChatParticipantsInvited>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onMessageAutoDeleteTimerChangedEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<MessageAutoDeleteTimerChanged>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<MessageAutoDeleteTimerChanged>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<MessageAutoDeleteTimerChanged>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onCommonEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<CommonEvent>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<CommonEvent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<CommonEvent>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onGroupEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<GroupEvent>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<GroupEvent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<GroupEvent>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onSupergroupEvent( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<SupergroupEvent>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<SupergroupEvent>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<SupergroupEvent>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|  | ||||
| suspend fun BehaviourContext.onChannelChatCreated( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<ChannelChatCreated>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<ChannelChatCreated>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ChannelChatCreated>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onDeleteChatPhoto( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<DeleteChatPhoto>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<DeleteChatPhoto>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<DeleteChatPhoto>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onGroupChatCreated( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<GroupChatCreated>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<GroupChatCreated>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<GroupChatCreated>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onLeftChatMember( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<LeftChatMember>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<LeftChatMember>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<LeftChatMember>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onNewChatMembers( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<NewChatMembers>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<NewChatMembers>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatMembers>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onNewChatPhoto( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<NewChatPhoto>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<NewChatPhoto>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatPhoto>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onNewChatTitle( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<NewChatTitle>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<NewChatTitle>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<NewChatTitle>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onPinnedMessage( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<PinnedMessage>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<PinnedMessage>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<PinnedMessage>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onProximityAlertTriggered( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<ProximityAlertTriggered>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<ProximityAlertTriggered>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<ProximityAlertTriggered>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onSupergroupChatCreated( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (ChatEventMessage<SupergroupChatCreated>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in ChatEventMessage<SupergroupChatCreated>, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, ChatEventMessage<SupergroupChatCreated>> | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onEvent(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||
|  | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptions | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptionsAsync | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.* | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.expectFlow | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.optionallyWrapWithLaunch | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByUserInlineQueryMarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.utils.asInlineQueryUpdate | ||||
| import dev.inmo.tgbotapi.extensions.utils.extensions.sourceChat | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.query.* | ||||
| @@ -11,7 +12,7 @@ import dev.inmo.tgbotapi.types.InlineQueries.query.* | ||||
| internal suspend inline fun <reified T : InlineQuery> BehaviourContext.onInlineQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     noinline additionalFilter: (suspend (T) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in T, Any> = ByUserInlineQueryMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, T> | ||||
| ) = flowsUpdatesFilter.expectFlow(bot) { | ||||
|     it.asInlineQueryUpdate() ?.data ?.let { query -> | ||||
| @@ -21,42 +22,42 @@ internal suspend inline fun <reified T : InlineQuery> BehaviourContext.onInlineQ | ||||
|             null | ||||
|         } | ||||
|     }.let(::listOfNotNull) | ||||
| }.subscribeSafelyWithoutExceptions( | ||||
| }.subscribeSafelyWithoutExceptionsAsync( | ||||
|     scope, | ||||
|     optionallyWrapWithLaunch(performInParallel) { triggerQuery -> | ||||
|         doInSubContextWithUpdatesFilter( | ||||
|             updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|                 { it.sourceChat() ?.id ?.chatId == triggerQuery.from.id.chatId } | ||||
|             } else { | ||||
|                 null | ||||
|             }, | ||||
|             stopOnCompletion = false | ||||
|         ) { | ||||
|             scenarioReceiver(triggerQuery) | ||||
|         } | ||||
|     markerFactory::invoke | ||||
| ) { triggerQuery -> | ||||
|     doInSubContextWithUpdatesFilter( | ||||
|         updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|             { it.sourceChat() ?.id ?.chatId == triggerQuery.from.id.chatId } | ||||
|         } else { | ||||
|             null | ||||
|         }, | ||||
|         stopOnCompletion = false | ||||
|     ) { | ||||
|         scenarioReceiver(triggerQuery) | ||||
|     } | ||||
| ) | ||||
| } | ||||
|  | ||||
|  | ||||
| suspend fun BehaviourContext.onAnyInlineQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (InlineQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in InlineQuery, Any> = ByUserInlineQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, InlineQuery> | ||||
| ) = onInlineQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onInlineQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|  | ||||
|  | ||||
| suspend fun BehaviourContext.onBaseInlineQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (BaseInlineQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in BaseInlineQuery, Any> = ByUserInlineQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, BaseInlineQuery> | ||||
| ) = onInlineQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onInlineQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|  | ||||
|  | ||||
| suspend fun BehaviourContext.onLocationInlineQuery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (LocationInlineQuery) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in LocationInlineQuery, Any> = ByUserInlineQueryMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, LocationInlineQuery> | ||||
| ) = onInlineQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onInlineQuery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|   | ||||
| @@ -2,10 +2,11 @@ | ||||
|  | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||
|  | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptions | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptionsAsync | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.* | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.expectFlow | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.optionallyWrapWithLaunch | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByChatMediaGroupMarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.utils.asSentMediaGroupUpdate | ||||
| import dev.inmo.tgbotapi.extensions.utils.extensions.sourceChat | ||||
| import dev.inmo.tgbotapi.extensions.utils.shortcuts.chat | ||||
| @@ -19,7 +20,7 @@ import dev.inmo.tgbotapi.utils.PreviewFeature | ||||
| internal suspend inline fun <reified T : MediaGroupContent> BehaviourContext.buildMediaGroupTrigger( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     noinline additionalFilter: (suspend (List<MediaGroupMessage<T>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<T>>, Any> = ByChatMediaGroupMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<T>>> | ||||
| ) = flowsUpdatesFilter.expectFlow(bot) { update -> | ||||
|     update.asSentMediaGroupUpdate() ?.data ?.let { mediaGroup -> | ||||
| @@ -29,61 +30,61 @@ internal suspend inline fun <reified T : MediaGroupContent> BehaviourContext.bui | ||||
|             null | ||||
|         } | ||||
|     } ?: emptyList() | ||||
| }.subscribeSafelyWithoutExceptions( | ||||
| }.subscribeSafelyWithoutExceptionsAsync( | ||||
|     scope, | ||||
|     optionallyWrapWithLaunch(performInParallel) { mediaGroup -> | ||||
|         val mediaGroupChat = mediaGroup.chat!! | ||||
|         doInSubContextWithUpdatesFilter( | ||||
|             updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|                 { it.sourceChat() ?.id ?.chatId == mediaGroupChat.id.chatId } | ||||
|             } else null, | ||||
|             stopOnCompletion = false | ||||
|         ) { | ||||
|             scenarioReceiver(mediaGroup) | ||||
|         } | ||||
|     markerFactory::invoke | ||||
| ) { mediaGroup -> | ||||
|     val mediaGroupChat = mediaGroup.chat!! | ||||
|     doInSubContextWithUpdatesFilter( | ||||
|         updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|             { it.sourceChat() ?.id ?.chatId == mediaGroupChat.id.chatId } | ||||
|         } else null, | ||||
|         stopOnCompletion = false | ||||
|     ) { | ||||
|         scenarioReceiver(mediaGroup) | ||||
|     } | ||||
| ) | ||||
| } | ||||
|  | ||||
| suspend fun BehaviourContext.onMediaGroup( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (List<MediaGroupMessage<MediaGroupContent>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<MediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<MediaGroupContent>>> | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onPlaylist( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (List<MediaGroupMessage<AudioMediaGroupContent>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<AudioMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<AudioMediaGroupContent>>> | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onDocumentsGroup( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (List<MediaGroupMessage<DocumentMediaGroupContent>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<DocumentMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<DocumentMediaGroupContent>>> | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVisualGallery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (List<MediaGroupMessage<VisualMediaGroupContent>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<VisualMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<VisualMediaGroupContent>>> | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVisualMediaGroup( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (List<MediaGroupMessage<VisualMediaGroupContent>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<VisualMediaGroupContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<VisualMediaGroupContent>>> | ||||
| ) = onVisualGallery(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = onVisualGallery(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onPhotoGallery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (List<MediaGroupMessage<PhotoContent>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<PhotoContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<PhotoContent>>> | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
| suspend fun BehaviourContext.onVideoGallery( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (List<MediaGroupMessage<VideoContent>>) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in List<MediaGroupMessage<VideoContent>>, Any> = ByChatMediaGroupMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, List<MediaGroupMessage<VideoContent>>> | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, performInParallel, scenarioReceiver) | ||||
| ) = buildMediaGroupTrigger(includeFilterByChatInBehaviourSubContext, additionalFilter, markerFactory, scenarioReceiver) | ||||
|  | ||||
|   | ||||
| @@ -1,9 +1,10 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling | ||||
|  | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptions | ||||
| import dev.inmo.micro_utils.coroutines.subscribeSafelyWithoutExceptionsAsync | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.* | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.expectFlow | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.optionallyWrapWithLaunch | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByChatMessageMarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory | ||||
| import dev.inmo.tgbotapi.extensions.utils.asMessageUpdate | ||||
| import dev.inmo.tgbotapi.extensions.utils.asPassportMessage | ||||
| import dev.inmo.tgbotapi.extensions.utils.extensions.sourceChat | ||||
| @@ -13,7 +14,7 @@ import dev.inmo.tgbotapi.types.passport.encrypted.abstracts.EncryptedPassportEle | ||||
| internal suspend inline fun <reified T : EncryptedPassportElement> BehaviourContext.onPassportMessageWith( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     noinline additionalFilter: (suspend (PassportMessage) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in PassportMessage, Any> = ByChatMessageMarkerFactory, | ||||
|     noinline scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, PassportMessage> | ||||
| ) = flowsUpdatesFilter.expectFlow(bot) { | ||||
|     it.asMessageUpdate() ?.data ?.asPassportMessage() ?.let { message -> | ||||
| @@ -23,29 +24,29 @@ internal suspend inline fun <reified T : EncryptedPassportElement> BehaviourCont | ||||
|             null | ||||
|         } | ||||
|     }.let(::listOfNotNull) | ||||
| }.subscribeSafelyWithoutExceptions( | ||||
| }.subscribeSafelyWithoutExceptionsAsync( | ||||
|     scope, | ||||
|     optionallyWrapWithLaunch(performInParallel) { triggerMessage -> | ||||
|         doInSubContextWithUpdatesFilter( | ||||
|             updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|                 { it.sourceChat() ?.id ?.chatId == triggerMessage.chat.id.chatId } | ||||
|             } else null, | ||||
|             stopOnCompletion = false | ||||
|         ) { | ||||
|             scenarioReceiver(triggerMessage) | ||||
|         } | ||||
|     markerFactory::invoke | ||||
| ) { triggerMessage -> | ||||
|     doInSubContextWithUpdatesFilter( | ||||
|         updatesFilter = if (includeFilterByChatInBehaviourSubContext) { | ||||
|             { it.sourceChat() ?.id ?.chatId == triggerMessage.chat.id.chatId } | ||||
|         } else null, | ||||
|         stopOnCompletion = false | ||||
|     ) { | ||||
|         scenarioReceiver(triggerMessage) | ||||
|     } | ||||
| ) | ||||
| } | ||||
|  | ||||
| suspend fun BehaviourContext.onPassportMessage( | ||||
|     includeFilterByChatInBehaviourSubContext: Boolean = true, | ||||
|     additionalFilter: (suspend (PassportMessage) -> Boolean)? = null, | ||||
|     performInParallel: Boolean = true, | ||||
|     markerFactory: MarkerFactory<in PassportMessage, Any> = ByChatMessageMarkerFactory, | ||||
|     scenarioReceiver: BehaviourContextAndTypeReceiver<Unit, PassportMessage> | ||||
| ) = onPassportMessageWith<EncryptedPassportElement>( | ||||
|     includeFilterByChatInBehaviourSubContext, | ||||
|     additionalFilter, | ||||
|     performInParallel, | ||||
|     markerFactory, | ||||
|     scenarioReceiver | ||||
| ) | ||||
|  | ||||
|   | ||||
| @@ -0,0 +1,17 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.CallbackQuery.CallbackQuery | ||||
|  | ||||
| object ByUserCallbackQueryMarkerFactory : MarkerFactory<CallbackQuery, Any> { | ||||
|     override suspend fun invoke(data: CallbackQuery) = data.user | ||||
| } | ||||
|  | ||||
| object ByIdCallbackQueryMarkerFactory : MarkerFactory<CallbackQuery, Any> { | ||||
|     override suspend fun invoke(data: CallbackQuery) = data.id | ||||
| } | ||||
|  | ||||
| object ByChatInstanceCallbackQueryMarkerFactory : MarkerFactory<CallbackQuery, Any> { | ||||
|     override suspend fun invoke(data: CallbackQuery) = data.chatInstance | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -0,0 +1,7 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.ChatMemberUpdated | ||||
|  | ||||
| object ByChatChatMemberUpdatedMarkerFactory : MarkerFactory<ChatMemberUpdated, Any> { | ||||
|     override suspend fun invoke(data: ChatMemberUpdated) = data.chat | ||||
| } | ||||
| @@ -0,0 +1,11 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.InlineQueries.query.InlineQuery | ||||
|  | ||||
| object ByUserInlineQueryMarkerFactory : MarkerFactory<InlineQuery, Any> { | ||||
|     override suspend fun invoke(data: InlineQuery) = data.from | ||||
| } | ||||
|  | ||||
| object ByIdInlineQueryMarkerFactory : MarkerFactory<InlineQuery, Any> { | ||||
|     override suspend fun invoke(data: InlineQuery) = data.id | ||||
| } | ||||
| @@ -0,0 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories | ||||
|  | ||||
| fun interface MarkerFactory<T, M> { | ||||
|     suspend operator fun invoke(data: T): M | ||||
| } | ||||
| @@ -0,0 +1,8 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories | ||||
|  | ||||
| import dev.inmo.tgbotapi.extensions.utils.shortcuts.chat | ||||
| import dev.inmo.tgbotapi.types.message.abstracts.MediaGroupMessage | ||||
|  | ||||
| object ByChatMediaGroupMarkerFactory : MarkerFactory<List<MediaGroupMessage<*>>, Any> { | ||||
|     override suspend fun invoke(data: List<MediaGroupMessage<*>>) = data.chat ?: error("Data must not be empty") | ||||
| } | ||||
| @@ -0,0 +1,7 @@ | ||||
| package dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.message.abstracts.Message | ||||
|  | ||||
| object ByChatMessageMarkerFactory : MarkerFactory<Message, Any> { | ||||
|     override suspend fun invoke(data: Message) = data.chat | ||||
| } | ||||
		Reference in New Issue
	
	Block a user