2021-09-13 17:30:01 +00:00
|
|
|
@file:Suppress("unused")
|
|
|
|
|
2021-01-07 12:17:50 +00:00
|
|
|
package dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling
|
2021-01-07 11:57:08 +00:00
|
|
|
|
2022-05-07 18:27:48 +00:00
|
|
|
import dev.inmo.micro_utils.coroutines.launchSafelyWithoutExceptions
|
|
|
|
import dev.inmo.micro_utils.coroutines.runCatchingSafely
|
2021-01-19 12:50:45 +00:00
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.*
|
2021-09-13 17:30:01 +00:00
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.filters.CallbackQueryFilterByUser
|
2022-07-31 11:49:48 +00:00
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.*
|
2021-06-26 06:15:52 +00:00
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.ByUserCallbackQueryMarkerFactory
|
|
|
|
import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.marker_factories.MarkerFactory
|
2022-08-05 10:31:39 +00:00
|
|
|
import dev.inmo.tgbotapi.extensions.utils.callbackQueryUpdateOrNull
|
2022-04-21 16:42:54 +00:00
|
|
|
import dev.inmo.tgbotapi.types.queries.callback.*
|
2021-09-13 17:30:01 +00:00
|
|
|
import dev.inmo.tgbotapi.types.update.abstracts.Update
|
2022-05-07 18:27:48 +00:00
|
|
|
import kotlinx.coroutines.Job
|
2021-01-07 11:57:08 +00:00
|
|
|
|
2021-10-13 08:22:01 +00:00
|
|
|
internal suspend inline fun <BC : BehaviourContext, reified T : CallbackQuery> BC.onCallbackQuery(
|
2022-04-21 09:42:32 +00:00
|
|
|
initialFilter: SimpleFilter<T>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
noinline subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, T, Update>? = CallbackQueryFilterByUser,
|
2021-06-26 06:15:52 +00:00
|
|
|
markerFactory: MarkerFactory<in T, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
noinline scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, T>
|
2021-09-13 17:30:01 +00:00
|
|
|
) = on(markerFactory, initialFilter, subcontextUpdatesFilter, scenarioReceiver) {
|
2022-08-05 10:31:39 +00:00
|
|
|
(it.callbackQueryUpdateOrNull() ?.data as? T) ?.let(::listOfNotNull)
|
2021-06-26 06:15:52 +00:00
|
|
|
}
|
2021-01-07 11:57:08 +00:00
|
|
|
|
2022-05-07 18:27:48 +00:00
|
|
|
/**
|
|
|
|
* @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].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @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
|
|
|
|
*/
|
|
|
|
internal suspend inline fun <BC : BehaviourContext, reified T : DataCallbackQuery> BC.onDataCallbackQueryCounted(
|
2022-05-07 18:39:41 +00:00
|
|
|
initialFilter: SimpleFilter<T>? = null,
|
2022-05-07 18:27:48 +00:00
|
|
|
noinline subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, T, Update>? = CallbackQueryFilterByUser,
|
|
|
|
markerFactory: MarkerFactory<in T, Any> = ByUserCallbackQueryMarkerFactory,
|
|
|
|
noinline scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, T>
|
|
|
|
): Job {
|
|
|
|
val newInitialFilter = SimpleFilter<DataCallbackQuery> {
|
|
|
|
it is T && initialFilter ?.invoke(it) ?: true
|
2022-05-07 18:39:41 +00:00
|
|
|
}::invoke
|
2022-05-07 18:27:48 +00:00
|
|
|
return runCatchingSafely {
|
|
|
|
onCallbackQuery (
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
}.onFailure {
|
|
|
|
triggersHolder.handleableCallbackQueriesDataHolder.unregisterHandleable(newInitialFilter)
|
|
|
|
}.onSuccess {
|
|
|
|
triggersHolder.handleableCallbackQueriesDataHolder.registerHandleable(newInitialFilter)
|
|
|
|
it.invokeOnCompletion {
|
|
|
|
runCatching {
|
|
|
|
launchSafelyWithoutExceptions {
|
|
|
|
triggersHolder.handleableCallbackQueriesDataHolder.unregisterHandleable(newInitialFilter)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}.getOrThrow()
|
|
|
|
}
|
|
|
|
|
2021-09-15 08:58:45 +00:00
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onDataCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<DataCallbackQuery>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, DataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in DataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, DataCallbackQuery>
|
2022-05-07 18:27:48 +00:00
|
|
|
) = onDataCallbackQueryCounted(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
2021-09-15 08:58:45 +00:00
|
|
|
|
2022-04-26 07:22:00 +00:00
|
|
|
/**
|
|
|
|
* @param dataRegex Will be used with [initialFilter] as [initialFilter] for upstream [onDataCallbackQuery] to filter
|
|
|
|
* [DataCallbackQuery] with [DataCallbackQuery.data] [String.matches] to [dataRegex]
|
|
|
|
* @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].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @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 <BC : BehaviourContext> BC.onDataCallbackQuery(
|
|
|
|
dataRegex: Regex,
|
|
|
|
initialFilter: SimpleFilter<DataCallbackQuery>? = null,
|
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, DataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
|
|
|
markerFactory: MarkerFactory<in DataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, DataCallbackQuery>
|
|
|
|
) = onDataCallbackQuery(
|
2022-07-31 11:49:48 +00:00
|
|
|
initialFilter = initialFilter * {
|
2022-04-26 07:22:00 +00:00
|
|
|
it.data.matches(dataRegex)
|
|
|
|
},
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param data Will be converted to [Regex] via its constructor and pass it to upstream [onDataCallbackQuery]
|
|
|
|
* @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].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @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 <BC : BehaviourContext> BC.onDataCallbackQuery(
|
|
|
|
data: String,
|
|
|
|
initialFilter: SimpleFilter<DataCallbackQuery>? = null,
|
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, DataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
|
|
|
markerFactory: MarkerFactory<in DataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, DataCallbackQuery>
|
|
|
|
) = onDataCallbackQuery(
|
|
|
|
Regex(data),
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
|
2021-09-15 08:58:45 +00:00
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onGameShortNameCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<GameShortNameCallbackQuery>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, GameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in GameShortNameCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, GameShortNameCallbackQuery>
|
2021-10-03 14:40:42 +00:00
|
|
|
) = onCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
2021-09-15 08:58:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onInlineMessageIdCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<InlineMessageIdCallbackQuery>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, InlineMessageIdCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in InlineMessageIdCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, InlineMessageIdCallbackQuery>
|
2021-10-03 14:40:42 +00:00
|
|
|
) = onCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
2021-09-15 08:58:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onInlineMessageIdDataCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<InlineMessageIdDataCallbackQuery>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, InlineMessageIdDataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in InlineMessageIdDataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, InlineMessageIdDataCallbackQuery>
|
2022-05-07 18:27:48 +00:00
|
|
|
) = onDataCallbackQueryCounted(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
2021-09-15 08:58:45 +00:00
|
|
|
|
2022-04-26 07:22:00 +00:00
|
|
|
/**
|
|
|
|
* @param dataRegex Will be used with [initialFilter] as [initialFilter] for upstream [onInlineMessageIdDataCallbackQuery]
|
|
|
|
* to filter [InlineMessageIdDataCallbackQuery] with [InlineMessageIdDataCallbackQuery.data] [String.matches] to [dataRegex]
|
|
|
|
* @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].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @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 <BC : BehaviourContext> BC.onInlineMessageIdDataCallbackQuery(
|
|
|
|
dataRegex: Regex,
|
|
|
|
initialFilter: SimpleFilter<InlineMessageIdDataCallbackQuery>? = null,
|
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, InlineMessageIdDataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
|
|
|
markerFactory: MarkerFactory<in InlineMessageIdDataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, InlineMessageIdDataCallbackQuery>
|
|
|
|
) = onInlineMessageIdDataCallbackQuery(
|
2022-07-31 11:49:48 +00:00
|
|
|
initialFilter = initialFilter * {
|
2022-04-26 07:22:00 +00:00
|
|
|
it.data.matches(dataRegex)
|
|
|
|
},
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param data Will be converted to [Regex] via its constructor and pass it to upstream [onInlineMessageIdDataCallbackQuery]
|
|
|
|
* @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].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @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 <BC : BehaviourContext> BC.onInlineMessageIdDataCallbackQuery(
|
|
|
|
data: String,
|
|
|
|
initialFilter: SimpleFilter<InlineMessageIdDataCallbackQuery>? = null,
|
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, InlineMessageIdDataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
|
|
|
markerFactory: MarkerFactory<in InlineMessageIdDataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, InlineMessageIdDataCallbackQuery>
|
|
|
|
) = onInlineMessageIdDataCallbackQuery(
|
|
|
|
Regex(data),
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
|
2021-09-15 08:58:45 +00:00
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onInlineMessageIdGameShortNameCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<InlineMessageIdGameShortNameCallbackQuery>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, InlineMessageIdGameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in InlineMessageIdGameShortNameCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, InlineMessageIdGameShortNameCallbackQuery>
|
2021-09-13 17:30:01 +00:00
|
|
|
) = onCallbackQuery(
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
2021-09-15 08:58:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onMessageCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<MessageCallbackQuery>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, MessageCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in MessageCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, MessageCallbackQuery>
|
2021-10-03 14:40:42 +00:00
|
|
|
) = onCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
2021-09-15 08:58:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onMessageDataCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<MessageDataCallbackQuery>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, MessageDataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in MessageDataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, MessageDataCallbackQuery>
|
2022-05-07 18:27:48 +00:00
|
|
|
) = onDataCallbackQueryCounted(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
2021-09-15 08:58:45 +00:00
|
|
|
|
2022-04-26 07:22:00 +00:00
|
|
|
/**
|
|
|
|
* @param dataRegex Will be used with [initialFilter] as [initialFilter] for upstream [onMessageDataCallbackQuery] to filter
|
|
|
|
* [MessageDataCallbackQuery] with [MessageDataCallbackQuery.data] [String.matches] to [dataRegex]
|
|
|
|
* @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].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @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 <BC : BehaviourContext> BC.onMessageDataCallbackQuery(
|
|
|
|
dataRegex: Regex,
|
|
|
|
initialFilter: SimpleFilter<MessageDataCallbackQuery>? = null,
|
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, MessageDataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
|
|
|
markerFactory: MarkerFactory<in MessageDataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, MessageDataCallbackQuery>
|
|
|
|
) = onMessageDataCallbackQuery(
|
2022-07-31 11:49:48 +00:00
|
|
|
initialFilter = initialFilter * {
|
2022-04-26 07:22:00 +00:00
|
|
|
it.data.matches(dataRegex)
|
|
|
|
},
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param data Will be converted to [Regex] via its constructor and pass it to upstream [onMessageDataCallbackQuery]
|
|
|
|
* @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].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
|
|
|
* @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 <BC : BehaviourContext> BC.onMessageDataCallbackQuery(
|
|
|
|
data: String,
|
|
|
|
initialFilter: SimpleFilter<MessageDataCallbackQuery>? = null,
|
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, MessageDataCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
|
|
|
markerFactory: MarkerFactory<in MessageDataCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, MessageDataCallbackQuery>
|
|
|
|
) = onMessageDataCallbackQuery(
|
|
|
|
Regex(data),
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
|
|
|
|
2021-09-15 08:58:45 +00:00
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onMessageGameShortNameCallbackQuery(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<MessageGameShortNameCallbackQuery>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, MessageGameShortNameCallbackQuery, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in MessageGameShortNameCallbackQuery, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, MessageGameShortNameCallbackQuery>
|
2021-09-13 17:30:01 +00:00
|
|
|
) = onCallbackQuery(
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|
2021-09-15 08:58:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @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,
|
2021-09-21 15:36:52 +00:00
|
|
|
* this filter will be used if you will call [dev.inmo.tgbotapi.extensions.behaviour_builder.expectations.waitContentMessage].
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.BehaviourContextAndTwoTypesReceiver] function to create your own.
|
|
|
|
* Use [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus] or [dev.inmo.tgbotapi.extensions.behaviour_builder.utils.times]
|
|
|
|
* to combinate several filters
|
2021-09-15 08:58:45 +00:00
|
|
|
* @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
|
|
|
|
*/
|
2021-10-13 08:22:01 +00:00
|
|
|
suspend fun <BC : BehaviourContext> BC.onUnknownCallbackQueryType(
|
2021-09-13 17:30:01 +00:00
|
|
|
initialFilter: SimpleFilter<UnknownCallbackQueryType>? = null,
|
2021-10-13 08:22:01 +00:00
|
|
|
subcontextUpdatesFilter: CustomBehaviourContextAndTwoTypesReceiver<BC, Boolean, UnknownCallbackQueryType, Update>? = CallbackQueryFilterByUser,
|
2021-09-13 17:30:01 +00:00
|
|
|
markerFactory: MarkerFactory<in UnknownCallbackQueryType, Any> = ByUserCallbackQueryMarkerFactory,
|
2021-10-13 08:22:01 +00:00
|
|
|
scenarioReceiver: CustomBehaviourContextAndTypeReceiver<BC, Unit, UnknownCallbackQueryType>
|
2021-09-13 17:30:01 +00:00
|
|
|
) = onCallbackQuery(
|
|
|
|
initialFilter,
|
|
|
|
subcontextUpdatesFilter,
|
|
|
|
markerFactory,
|
|
|
|
scenarioReceiver
|
|
|
|
)
|